出处:掘金

原作者:前端九哥


[[005.CSS 布局:Flex & Grid|CSS 布局(Flex & Grid)]]

只用两行 CSS,就能让卡片、图片、内容块自动适应各种屏幕宽度,彻底摆脱复杂的媒体查询!秘诀就是 CSS Grid 的 auto-fill 和 auto-fit

![[屏幕自适应.webp]]

基础概念

假设有这样一个需求:

只需在父元素加两行 CSS 就能实现:

/* 父元素 */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* 子元素 */
.item {
  height: 200px;
  background-color: rgb(141, 141, 255);
  border-radius: 10px;
}
  1. grid-template-columns
  2. repeat(auto-fit, ...)
  3. minmax(200px, 1fr)

综合起来 grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); 这行代码的意思就是:

auto-fill Vs. auto-fit

auto-fill

尽可能多地填充列,即使没有内容也会“占位”

auto-fit

自动适应内容,能合并多余空列,不占位

直观对比

假设容器宽度能容纳 10 个 200px 的卡片,但你只放了 5 个卡片:

![[auto-fill Vs. auto-fit.webp]]

属性 空轨道 内容拉伸 适用场景
auto-fill 保留 固定列数、占位网格
auto-fit 折叠 流式布局、拉伸填充